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© Microcircuit pour carte a puce multi -applica- 
tions comportant notamment une memoire ROM 
(12), une memoire programmable (13) et un circuit 
de controle d'adressage (14) de cette memoire 
programmable. 

Seton I'invention, la memoire programmable (13) 
est partagee en au moins une zone de repertoire 
(ZR) et une zone des applications (ZA), la zone de 
repertoire (ZR) comportant par application chargee, 
au moins un code de reference d'une application i 
presente dans la zone ZA S ainsi que les adresses 
ZAji et ZA ih respectivement de debut et de fin de la 
zone ZAj allouee a cette application. 

Le microcircuit comporte egalement des moyens 
(25 a 50) pour inhiber toute commande (R, W ou E) 
de la memoire programmable (13) lorsqu'elle est 
relative a une adresse exterieure a Tintervalle ZAj, - 
ZA jh de 1'application en cours de traitement et sauf 
s'il s'agit d'une operation prioritaire specifiquement 
prevue par un programme fixe dans la memoire 
ROM (12). 

Application : carte a microcircuits. 
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La presente invention concerne un microcircuit 
pour carte a puce comprenant entre-autres : des 
moyens d'acces entree -sortie, au moins une 
memoire qui est programmable et accessible par 
un espace d'adressage a adresses consecutives, 
un circuit de controle d'adressage de cette me- 
moire programmable determinant soit une inhibi- 
tion, soit une validation des commandes d'ecriture 
et/ou de lecture par la comparaison de I'adresse 
demandee avec deux valeurs limites de debut et 
de fin d'une zone particuliere d'adresses, limites 
qui sont memorisees au sein du circuit de controle 
d'adressage lequel circuit comporte egafement une 
voie d'autorisation prioritaire permettant de s'af- 
franchir temporairement de ladite inhibition dans 
des circonstances predeterminees et particulieres. 

Un tel microcircuit est notamment connu du 
document FR 2 304 989. 

[.'application dans le domaine bancaire des 
cartes portatives au sein desquelles est incorpore 
un circuit integre electronique (encore appele 
"puce") est bien connue ainsi que la grande se- 
curity de fonctionnement qui en resulte. II est en 
effet pratiquement impossible d'acceder a certai - 
nes donnees inscrites dans des zones protegees 
du microcircuit sans le detruire. Par ailleurs, lors de 
I'utilisation, un protocole d'identification faisant in- 
tervene un code personnel et secret, inscrit dans 
une zone protegee du microcircuit, permet d'in- 
terdire toute tentative d'usage de la carte si les 
conditions d f identification ne sont pas satisfaites. 

Dans le cas d'une carte bancaire, le fabricant 
de carte cree dans un premier temps des cartes 
dont le microcircuit est vierge de toute information 
personnalisee, puis dans un deuxieme temps, il y 
inscrit, par programmation des donnees secretes, 
personnalisant chaque carte. Les cartes sont en- 
suite protegees par des verrous technologiques 
irreversibles. 

Les codes personnels d'identification sont aiors 
envoyes a chaque utilisateur (clients de la ban- 
que), et, par une autre route, les cartes elles- 
memes sont expedites a la banque, ou les clients 
sont pries de venir les retirer. Ce systeme se 
revele d'une grande securite contre les tentatives 
d'usurpation. 

Bien entendu, une carte a puce est susceptible 
de servir a bien d'autres applications, en dehors du 
domaine bancaire, ou I'aspect pratique de porta- 
bility de la carte et de sa securite d'utilisation 
offrent des perspectives interessantes. 

On peut penser a developper un microcircuit 
specifique de chaque cas duplication particulier 
envisage mais il est plus economique et plus sim - 
pie de prevoir des microcircuits d'un type suffi- 
samment universel pour que Tune ou I'autre des 
applications envisagee y soit ensuite programmee. 



Dans cette perspective, des problemes appa- 
raissent deja du point de vue de la securite si on 
envisage de confier a une entite autre que le 
fabricant de microcircuit, le soin d'inscrire les 
5 donnees secretes d'identification et les donnees 
fonctionnelles de sa propre application. 

En effet une personne mal intentionnee ayant 
reussi a se procurer des cartes vierges et ayant 
par ailleurs pris connaissance des techniques 

w description d'une certaine application, serait sus- 
ceptible de recreer illicitement des cartes falsifies 
en utilisant une technique description de donnees 
qui imite I'originale. 

Or, I'entite emettrice de I'application, qui est 

75 etrangere au fabricant de microcircuit, peut desirer 
charger elle-meme les donnees de son applica- 
tion, entre-autres pour ne pas livrer ses secrets 
au fabricant de microcircuits. 

Ces difficultes relatives a la securite sont en - 

20 core aggravees dans le cas oti on envisage de 
creer des cartes dites "multi -application" d'un 
type universel, vierges a rorigine, et qui sont aptes 
a etre chargees successivement et dans un ordre 
de succession quelconque, de donnees et pro- 

25 grammes d'applications differents les uns des au - 
tres, par des entites emettrices qui sont etrangeres 
les unes aux autres. Le but recherche sera alors 
d'effectuer une allocation dynamique de la me- 
moire programmable dans des conditions de se- 

30 curite satisfaisantes. 

Le fabricant de microcircuits devrait pouvoir 
assurer une possibility de protection de plusieurs 
zones de memoire dont il ne connaft pas encore 
les limites individuelles, de maniere que chaque 

35 entite emettrice puisse proteger la zone ou elie a 
charge ses donnees fonctionnelles secretes, contre 
toute tentative de lecture ou d'ecriture provenant 
du deroulement d'une autre application, que ces 
tentatives proviennent d'une erreur de program - 

40 mation de I'entite ayant emis cette autre application 
ou qu^lles proviennent de la programmation illicite 
d'un fraudeur.On doit se rendre compte qu'il serait 
illusoire de confier a une plurality d'entites sus- 
ceptibles de charger diverses applications, des 

45 secrets de programmation relatifs au chargement 
des applications en esperant que ces secrets ne 
parviennent jamais dans les mains de personnes 
mal intentionnees. Une solution ne peut etre envi - 
sagee dans cette direction d'autant plus qu'une 

so entite bien qu'autorisee mais maladroite peut 
emettre une application contenant une erreur de 
programmation aboutissant a la destruction d'une 
donnee contenue dans une application etrangere a 
la sienne. 

55 L'invention vise tout particulierement le cas 

d'un microcircuit pour carte a puce du type multi - 
applications, dans lequel un haut niveau de se- 
curite est maintenu malgre que la carte soit fabri - 
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quee dans un etant vierge et qu'elle soit suscepti - 
ble d'etre chargee, dans un ordre indifferent, par 
des entites emettrices d'applications qui sont in- 
dependantes les unes des autres. En queique 
sorte, le microcircuit souhaite devrait disposer de 
verrous mobiles mais inviolables que ce soit en 
cours de chargement, de fonctionnement, ou par 
renvoi de signaux quelconques sur les acces 
d'entree -sortie. 

L'invention a pour but de fournir une solution a 
ce probleme technique. 

En effet, selon ('invention, un microcircuit pour 
carte a puce, d'un type conforme au paragraphe 
introductif, est caracterise en ce que, en vue d'un 
chargement et d'une exploitation de programmes 
d'applications independants les uns des autres, ie 
microcircuit est muni d'une unite centrafe de mi - 
croprocesseur, d'une memoire a lecture seule 
(ROM) contenant notamment des routines fonc- 
tionnelles exclusivement executables par I'unite 
centrale et sous sa dependance, en ce que dans 
I'espace d'adressage de la memoire programmable 
sont delimitees une zone dite de repertoire et une 
zone dite des applications, lesquelles zones sont 
exclusives I'une de I'autre, en ce que la zone de 
repertoire contient une table repertoire ou les 
adresses de debut et de fin ainsi qu'un code de 
reference de chacun des programmes d'applica- 
tions susceptible d'etre charge dans une portion de 
la zone des applications, sont inscrits au fur et a 
mesure du chargement desdits programmes et en 
utilisant une desdites routines fonctionnelles, en ce 
que le circuit de controle d'adressage est agence 
pour inhiber les commandes d'ecriture et de lec- 
ture de la memoire programmable pour des 
adresses qui se situent a I'exterieur de I'intervalle 
defini par les valeurs limites de debut et de fin 
d'une application designee prealablement sur les 
acces d'entree -sortie, limites qui sont memorisees 
dans des registres verrouillables, appeles registres 
de limites tandis que la voie dite d'autorisation 
prioritaire comporte des moyens pour s'affranchir 
de I'inhibition precitee en autorisant I'ecriture et la 
lecture de la zone de repertoire a la condition 
exclusive que ces operations soient effectuees au 
moyen d'une desdites routines fonctionnelles du - 
rant une etape operatoire predetermined durant 
laquelle les registres contenant les valeurs limites 
sont deverrouilles. 

Ainsi, dans le cas general ou un programme 
duplication est deja charge dans la carte et ap - 
pele par I'intermediaire les moyens d'acces 
entree - sortie, un protocole standard de recon- 
naissance de ('utilisation prevu parmi les routines 
fonctionnelles est execute. Apres quoi, une autre 
routine commande une recherche dans la table 
repertoire, les valeurs limites d'adresse corres- 
pondant au programme d'application demande, 



identifie dans ladite table par son code de refe - 
rence, et ces valeurs sont chargees dans les re - 
gistres de limites, deverrouilles durant cette etape 
initiale de fonctionnement. 

5 Le programme d'application demande est en - 

suite lance et simultanement, les registres de li - 
mites sont verrouilles de sorte que les demandes 
d'acces en ecriture ou en lecture qui designeraient 
la memoire programmable en dehors de la zone 

70 d'adresses comprise entre les valeurs limites me - 
morisees, resteront sans effet, par exemple jusqu'a 
ce que le microcircuit soit mis hors tension. La voie 
d'autorisation prioritaire est en effet refermee. De 
cette maniere, un programme d'application est seul 

75 a pouvoir lire ou ecrire dans la zone d'adresse qui 
lui est affectee et qui a ete fixee lors du charge - 
ment. Les autres programmes d'applications sont 
proteges contre toute tentative de lecture ou 
d'ecriture. 

20 En ce qui concerne le chargement de tout 

nouveau programme d'applications au sein de la 
carte, la securite provenant de ('absence d'interfe - 
rence avec d'autres zones de la memoire pro- 
grammable est assuree par des moyens similaires. 

25 Toute demande de chargement d'un pro- 

gramme d'application sur les moyens d'acces 
entree - sortie fait I'objet d'un protocole standard 
engage en liaison avec une routine fonctionnelle 
specialised contenue dans la memoire a lecture 

30 seule. Le code de reference de ('application ainsi 
que I'espace memoire requis doivent etre annon - 
ces durant ce protocole. Une routine fonctionnelle 
specifique a pour effet de rechercher dans la table 
repertoire quelle est la premiere adresse disponible 

35 dans la zone des applications (I'adresse qui suit 
I'adresse de fin la plus elevee des programmes 
d'applications deja charges ou la premiere adresse 
de la zone des applications lorsque la carte est 
vierge). L'adresse de fin de I'application demanded 

40 est calculee a partir de la demande d'espace me - 
moire annoncee precedemment. Lorsque cette 
adresse de fin d'application est compatible avec 
I'espace memoire de la zone des applications, les 
valeurs limites d'adresses de debut et de fin ainsi 

45 que le code de reference de I'application sont alors 
inscrits dans la table repertoire et ces valeurs li - 
mites sont chargees dans les registres de limites, 
toujours par le moyen d'une routine fonctionnelle 
preetablie et intangible. 

so Durant ces etapes qui precedent le charge- 

ment, les registres de limites sont deverrouilles, et 
ils peuvent le rester durant le chargement du pro - 
gramme d'application qui s'ensuit. La securite re - 
cherchee est neanmoins conserved par le fait que 

55 le chargement du programme d'application est ef- 
fectue sous le controle de I'unite centrale et par 
I'effet d'une routine fonctionnelle preetablie et sure 
qui exclut toute modification de contenu des re - 
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gistres de limites. 

On peut aussi prevoir un verrouillage de ces 
registres qui soit commande par programmation 
juste avant le chargement. 

Toute tentative de chargement en dehors des 
limites d'adresses etablies precedemment restera 
sans effet. L'operation de chargement peut §tre 
completee, si on le juge necessaire, par une routi - 
ne de verification des donnees chargees, une ve - 
rification de signature, un test de parite...etc... mais 
de telles operations n'auront pas pour effet d'ac- 
croftre de maniere significative la securite de 
fonctionnement du microcircuit selon I'invention. 

La voie d'autorisation prioritaire peut etre 
commandee de differentes manieres en appliquant 
des conditions logiques appropriees et en fonction 
du deroulement des etapes operatoires qui suivent 
la mise sous tension du microcircuit. 

Toutefois, selon un mode de mise en oeuvre 
prefere de I'invention, qui offre toute garantie du 
point de vue de la securite, le microcircuit se 
caracterise en ce qu'il comporte une bascule bis- 
table, placee dans un premier etat exclusivement 
lors d'une mise sous tension du microcircuit, puis 
placee dans un deuxieme etat oppose au premier, 
des qu'un compteur ordinal associe a I'unite cen- 
trale, contient une valeur d'adresse comprise dans 
I'espace d'adressage de la memoirs programma- 
ble, et en ce que cette bascule bistable delivre un 
signal de verrouillage/deverrouillage pour la com- 
mande de verrouillage des registres de limites et 
pour la commande de la voie d'autorisation priori - 
taire. 

Du fait qu'il est lie au compteur ordinal, le 
signal de verrouillage/deverrouillage fournit un 
moyen inviolable par un programme d'application 
quelconque pour le verrouillage des registres de 
limites et de la voie d'autorisation prioritaire, bien 
que la bascule bistable reste par sa nature un 
element reversible dans le temps. 

Comme les routines fonctionnelles qui ont pour 
objet de lire et/ou ecrire dans la table repertoire 
sont inscrites dans la memoire a lecture seule, le 
compteur ordinal pointe cette memoire pour les 
executer pas a pas. 

II suffit done de placer I'execution de ces rou - 
tines dans des etapes operatoires qui precedent 
toute execution de programme inscrit dans la me - 
moire programmable. La voie d'autorisation priori - 
taire est encore ouverte tant qu'il s'agit de routines 
executees sous le controie de I'unite centrale. Des 
que le compteur ordinal sera charge d'une adresse 
designant la memoire programmable, le signal de 
verrouillage/deverrouillage sera aussitot place dans 
son etat realisant le blocage, verrouillant les regis - 
tres de limites et interdisant I'acces a la table 
repertoire. 



En pratique ceci peut avantageusement etre 
realise dans un microcircuit caracterise en ce que 
le circuit de controie d'adressage comporte une 
porte OU dite de validation, dont la sortie com- 
5 mande la transmission des signaux d'ecriture et de 
lecture de la memoire programmable, en ce qu'une 
premiere entree de cette porte de validation regoit 
un signal resultant de la comparaison de toute 
adresse appelee avec le contenu des registre de 
70 limites, et une autre entree par laquelle s'effectue 
Tautorisation prioritaire, regoit un signal resultant 
du produit logique entre le signal de 
verrouillage/deverrouillage et le signal de sortie 
d'un decodeur d'adresses reconnaissant les seules 
75 adresses de la zone de repertoire. 

Jusqu'a present on a considere que I'espace 
d'adressage de la memoire programmable etait 
protege dans les conditions precitees relatives a la 
2one de repertoire et la zone des applications. 
20 II peut cependant etre utile de prevoir en outre 

une certaine zone de I'espace d'adressage de la 
memoire programmable qui soit librement acces - 
sible par tout programme d'application, par exem - 
pie pour y placer provisoirement des resultats de 
25 traitement ou pour transmettre des donnees d'une 
application a une autre. 

Sans amoindrir la securite, cette facilite peut 
etre obtenue aisement par une legere modification 
du circuit de controie d'adressage precedemment 
30 defini. Selon ce mode de mise en oeuvre, un 
microcircuit selon I'invention est caracterise en ce 
qu'une zone dite "publique" est en outre prevue 
dans I'espace d'adressage de la memoire pro - 
grammable, zone qui est distincte de la zone de 
35 repertoire et de la zone des applications, et en ce 
que le circuit de controie d'adressage comporte un 
decodeur d'adresse supplementaire, reconnaissant 
les seules adresses de la zone publique, qui deli - 
vre en sortie un signal applique & une entree 
40 supplementaire de la porte OU de validation. 

La description qui va suivre en regard des 
dessins annexes, donnes a titre d'exemples non 
limitatifs, fera bien comprendre en quoi consiste 
I'invention et comment elle peut etre realisee. 
45 La figure 1 represente un schema de principe 
d'un microcircuit selon I'invention, 
la figure 2 est un schema -bloc d'une portion 
du microcircuit delivrant un signal de 
verrouillage/deverrouillage et, 
so la figure 3 illustre schematiquement I'organisa- 
tion d'une zone particuliere de la memoire pro- 
grammable. 

La figure 1 represente le schema general et 
simplifie d'un microcircuit selon ('invention. 
55 Sur cette figure, et pour plus de clarete, les 

elements qui ne concernent pas directement Tin- 
vention n'ont pas ete representes. Le microcircuit 
comporte une unite centrale 10 de microproces- 
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seur, une memoire vive 11, une memoire a lecture 
seule 12, une memoire programmable 13 par 
exemple une EEPROM ainsi qu'un circuit de 
controle d'adressage 14 de la memoire program- 
mable 13. Les elements precites sont relies entre 
eux par un systeme de bus 15 vehiculant les 
adresses et les donnees entre ces differents ele - 
ments. Pour plus simplicity le systeme de bus 15 a 
ete represents par une liaison unique bien qu'on 
puisse, selon les cas, utiliser un bus d'adresses et 
un bus de donnees qui soit separes Tun de I'autre. 
Comme ceta est de pratique courante, le systeme 
de bus 15 peut encore etre un bus unique sur 
lequel les adresses et les donnees sont multi- 
plexees temporellement. A I'unite centrale 10 sont 
associes des moyens d'acces entree - sortie 16, 
moyens qui sont isoles du systeme de bus 15 de 
maniere a garantir un acces controle par I'unite 
centrale 10 aux zones sensibles du microcircuit 
contenant des donnees a proteger. 

Le circuit de controle d'adressage 14 regoit de 
I'unite centrale 10 un ensemble de liaisons de 
commande 20 parmi lesquelles figurent essentiel - 
lement les commandes d'ecriture W de lecture R 
et d'effacement E lorsqu'elles sont destinees a la 
memoire programmable 13. 

Les commandes de lecture et d'ecriture pour la 
memoire vive 11 et les commandes de lecture 
pour la memoire a lecture seule 12, n'ont pas ete 
representees, pour plus de clarte de la figure et du 
fait qu'elles n'interferent pas avec I'invention. Les 
commandes W, R et E destinees a la memoire 
programmable 13 peuvent etre inhibees ou vali - 
dees par le circuit de controle d'adressage 14 dans 
des conditions qui seront expliquees ci-apres. 
Conformement a une pratique en usage dans les 
microcontrdleurs, la memoire a lecture seule 12 et 
la memoire programmable 13 font partie d'un 
meme systeme d'adressage tandis que la memoire 
vive 11 est adressee de maniere distincte et ex- 
clusive de I'adressage des memoires 12 et 13. 
Dans I'espace d'adressage de la memoire pro- 
grammable 13 sont delimitees une zone de reper- 
toire 2R et une zone des applications ZA, zones 
qui sont exclusives Tune de I'autre et qui sont 
definies une fois pour toutes par construction. 

Initialement les zones ZR et ZA sont vierges. 
Le microcircuit peut etre charge de programmes 
d'applications independant les uns des autres dans 
un ordre et a des moments qui sont indifferents. 
Au fur et a mesure du chargement desdits pro- 
grammes ceux-ci vont etre inscrits successive - 
ment dans des zones distinctes ZAi , ...ZA it ...ZA n 
qui sont adjacentes et qui remplissent progressi - 
vement la zone des applications ZA. 

Bien entendu, chaque zone ZAi d'une applica- 
tion determinee peut egalement contenir des don - 
nees (autres que des codes operatoires) qui sont 



propres a cette application et/ou des emplace- 
ments memoire destines a recevoir des resultats 
de traitement. Selon I'invention la zone de reper- 
toire ZR contient une table repertoire ou les 

5 adresses de debut et de fin ainsi qu'un code de 
reference de chacun des programmes d'applica- 
tions charges dans la zone des applications sont 
inscrits lors du chargement desdits programmes. 
Ainsi, un i^ me programme d'application charge dans 

w la zone ZAj entre les adresses ZA i( et ZA jh respe - 
ctivement de debut et de fin du programme d'ap- 
plication i a ete charge au cours d'un protocole au 
cours duquel les adresses ZA M et ZA ih ont ete 
prealablement dSterminees et chargees dans la 

75 table repertoire de la zone de repertoire ZR ac- 
compagnes d'un code reference du programme 
d'application i. Le protocole de chargement qui 
vient d'etre mentionne utilise une desdites routines 
fonctionnelles inscrites de maniere immuable dans 

20 la memoire a lecture seule 12. 

Le circuit de controle d'adressage 14 est 
agence pour inhiber les commandes de lecture (R) 
d'ecriture (W) et d'effacement (E) destinees a la 
memoire programmable 13 pour des adresses qui 

25 se situent a I'exterieur de I'intervalle defini par les 
valeurs limites de debut ZA^ et de fin ZA jh d'une 
application ZA ( designee prealablement sur les 
acces d'entree/sortie 16. Pour ce faire, le systeme 
de bus 15 est partage des I'entree dans ie circuit 

30 de controle d'adressage 14 en un bus de donnees 

21 et un bus d'adresses 22. Le bus de donnees 21 
est applique en parallele sur deux registres ver- 
rouillables dits registres de limites 25, 26 respec- 
tivement, ou les adresses de debut et de fin d'une 

35 application en cours de traitement peuvent etre 
memorisees et verrouillees au moyen d'un signal 
de verrouillage/deverrouillage (LOC) provenant 
d'une borne 60. Le bus d'adresses 22, interne au 
circuit de controle d'adressage 14, est applique en 

40 parallele a deux comparateurs 28, 29 respective - 
ment associes aux registres de limites 25 et 26. Le 
comparateur 28 delivre un signal d'autorisation 
lorsque I'adresse courante sur le bus d'adresses 

22 est superieure ou egale a I'adresse de debut 
45 memorisee dans le registre de limites 25 tandis 

que le comparateur 29 delivre un deuxieme signal 
d'autorisation lorsque I'adresse courante sur le bus 
d'adresse 22 est inferieure ou egale a I'adresse 
limite de fin d'application memorisee dans le re- 

50 gistre 26. Les deux signaux d'autorisation delivres 
en sortie des comparateurs 28 et 29 sont appliques 
aux deux entrees d'une porte ET 30 dont la sortie 
31 presente un signal d'autorisation lorsque 
I'adresse courante presentee sur le bus d'adresse 

55 22 est comprise dans les limites des adresses 
memorisees dans les registres 25 et 26. Le signal 
d'autorisation present a la sortie 31 de la porte 30 
est applique via une porte OU 32, dite de valida- 
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tion, a Tune des entrees de trois portes ET 35, 36, 
37 dont I'autre entree de chacune d'elle regoit 
respectivement les commandes de lecture (R) 
ecriture (W) et d'effacement (E). Ces commandes 
ne sont done transmises a la memoire program - 
mable 13 que lorsque les portes ET 35, 36, 37 sont 
passantes e'est-a-dire lorsque I'adresse cou- 
rante presente sur le bus d'adresses 22 est com - 
prise ou egale aux limites d'adresses memorisees 
dans les registres 25 et 26 et au contraire ces 
commandes sont inhibees dans le cas ou I'adresse 
courante est exterieure a ces valeurs limites. 

La porte OU 32 constitue une partie de ce qui 
a ete appele precedemment voie d'autorisation 
prioritaire, du fait qu'elle comporte une deuxieme 
entree 40 sur laquelle est applique un signal d'au - 
torisation durant une etape operatoire predetermi - 
nee qui suit toute mise sous tension du microcir- 
cuit. 

Pour realiser ladite voie d'autorisation priori- 
taire, le signal de verrouillage/deverrouiilage 
(LOC) est inverse par un inverseur 41 et applique a 
une des deux entrees d'une porte ET 42. Sur 
I'autre entree de cette porte ET 42 est applique le 
signal de sortie d'un decodeur d'adresses 43 re - 
connaissant les seules adresses de la zone de 
repertoire (ZR) et fournissant a la porte ET 42 un 
signal d'autorisation lorsque I'adresse courante 
presentee sur le bus d'adresses 22 est comprise 
dans I'espace d'adressage de la zone de repertoire 
(ZR). La porte ET 42 effectue ainsi le produit 
logique entre le signal de 

verrouillage/deverrouiilage (LOC) et le signal de 
sortie du decodeur d'adresses 43 pour fournir un 
signal d'autorisation prioritaire a I'entree 40 de la 
porte de validation 32. Le decodeur d'adresses 43 
qui reconnaft uniquement des adresses de la zone 
de repertoire (ZR) de la memoire programmable 13 
peut etre d'un type tres simple lorsque le nombre 
d'octets de la zone de repertoire (ZR) peut s'ex - 
primer par une puissance entiere de deux telle 
qu'une valeur de 256 octets ou 512 octets etc. A 
titre d'exemple, la zone de repertoire peut avoir 
une adresse de debut exprimee en hexadecimal 
par la valeur 8000 et I'adresse de fin de cette zone 
par I'adresse hexadecimale 80FF. 

Le microcircuit represents a la figure 1 com - 
porte encore une disposition optionnelle selon la- 
quelle une zone dite "publique" ZB est prevue 
dans I'espace d'adressage de la memoire pro- 
grammable 13, zone qui est distincte de la zone de 
repertoire ZR et de la zone des applications ZA et 
que I'on a fait figurer a titre d'exemple entre les 
zones ZR et ZA et adjacente a celles-ci. Du fait 
que I'on a prevu un acces inconditionnel a cette 
zone publique ZP, la porte de validation 32 com - 
porte une troisieme entree 50 par laquelle est 
applique un signal de validation provenant d'un 



decodeur d'adresses 51 similaire au decodeur 
d'adresses 43 a I'exception pres qu'il ne reconnait 
que les seules adresses de la zone publique ZP de 
la memoire programmable 13. 
5 Ainsi que cela a deja ete mentionne, le signal 

de verrouillage/deverrouiilage (LOC) est place dans 
un etat de deverrouillage (LOC = 0) durant une 
etape operatoire predeterminee qui suit toute mise 
sous tension du microcircuit. II peut etre genere 
w par tous systemes logiques convenables permet- 
tant d'autoriser le chargement des registres de 
limites 25 et 26 et de debloquer la porte ET 42 
pour permettre la lecture et/ou I'ecriture de la table 
repertoire situee dans la zone de repertoires ZR. 
15 Selon un mode de mise en oeuvre de I'inven - 

tion particulierement avantageux pour la securite 
elevee qu'il procure, le signal de 
verrouillage/deverrouiilage (LOC) est produit en 
liaison avec le contenu d'un compteur ordinal tel 
20 qu'il est generalement connu et associe a une 
unite centrale de microprocesseur. 

On se reporte maintenant a la figure 2 pour la 
description de cette portion du microcircuit. 

Sur cette figure, on a represents un compteur 
25 ordinal 55 qui fait partie de I'unite centrale 10 et 
qui permet ('execution pas a pas de routines 
fonctionneiles contenues dans la memoire a lecture 
seule 12. Cette disposition est par ailleurs classi- 
que dans tous les microcontroleurs ou micropro- 
30 cesseurs et ne necessite pas, de ce fait, une 
description detaillee. Le compteur ordinal 55 est 
relie a un decodeur 56, 57 qui actionne a sa sortie, 
via une porte OU 66 une bascule bistable 58, par 
exemple de type RS, lorsque le contenu du 
as compteur ordinal 55 depasse une certaine valeur 
d'adresse qui dans I'exemple illustre a pour limite 
la valeur hexadecimale 7FFF. Cette limite 
d'adresse correspond au cas ou la memoire pro- 
grammable a son adresse la plus basse exprimee 
40 en hexadecimal par la valeur 8000. Une routine 
fonctionnelle, par ailleurs classique en matiere de 
microcontroleur, effectue la remise a zero d'un 
certain nombre de registre et dans le cas precis, 
applique un signal de remise a zero de la bascule 
45 bistable 58 sur son entree de remise a zero 59. La 
bascule bistable 58 delivre en definitive le signal 
de verrouillage/deverrouiilage (LOC) sur la borne 
60 representee egalement a la figure 1 , a I'entree 
du circuit de controle d'adressage 14. 
so A la suite d'une mise sous tension du micro - 

circuit, et tant que I'unite centrale 10 execute les 
routines fonctionneiles contenues dans la memoire 
a lecture seule 12, le compteur ordinal 55 designe 
des adresses de programme qui sont relatives a 
55 cette meme memoire a lecture seule et la bascule 
bistable 58 delivre un signal de deverrouillage 
(LOC = 0). La table de repertoire peut etre lue ou 
ecrite sous le controle de I'unite centrale 10 et les 
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registres de limites 25, 26 peuvent etre charges 
par cette meme unite centrale. Au contraire, des 
lors qu'un programme d'application est appele (de 
sorte que I'adresse contenue dans le compteur 
ordinal 55 depasse necessairement I'adresse 
hexadecimale 7FFF, donnee comme limite dans 
I'exemple) la bascule bistable 58 est placee dans 
I'etat oppose au premier etat et delivre un signal 
de verrouillage sur la borne 60 (LOC = 1). Les 
registres de limites 25 et 26 ainsi que la voie 
d'autorisation prioritaire seront desormais verrouil- 
les jusqu'a la prochaine mise hors tension du mi - 
crocircuit. Comme on le voit cette disposition offre 
toute securite pour garantir une absence d'interfe- 
rence entre les differents programmes d'applica- 
tions susceptibles d'etre charges dans la zone des 
applications ZA. 

La porte OU 66 permet egalement une variante 
de fonctionnement selon laquelle le signal de ver- 
rouillage (LOC = 1) peut etre produit par une 
routine specifique contenue dans la memoire ROM 
12, et done meme si le contenu du compteur n'a 
pas encore depasse la valeur limite de 7FFF. La 
routine fonctionnelle prevue a cet effet impose a 
I'unite centrale 10 d'emettre un signal de com- 
mande sur une liaison 67 qui est appliquee a une 
deuxieme entree de la porte OU 66. On peut done 
ainsi emettre un signal de verrouillage par pro- 
grammation qui subsistera jusqu'a la prochaine 
remise a zero. Cette disposition permet d'accrottre 
encore la securite pendant le chargement d'un 
nouveau programme d'application et pendant 
I'execution d'une application qui ne ferait appel 
qu'a des routines contenues dans la memoire ROM 
12 et dont la zone ZA t reservee dans la memoire 
programmable ne contiendrait que des donnees (et 
aucun code operatoire). 

A I'aide de la figure 3, on va expliquer succin- 
tement comment la zone de repertoire ZR de la 
memoire programmable 13 peut etre organisee. La 
figure 3 se refere par ailleurs a un exemple dont 
les valeurs sont purement arbitraires et n'ont pas 
d'autre but que de rendre les explications plus 
claires. 

On suppose que la zone repertoire de la me - 
moire programmable 13 commence a I'adresse 
hexadecimale 8000 et finit a I'adresse 80FF. Dans 
cette zone d'un volume de 256 octets, on peut 
prevoir, si on le desire, une portion designee par 
ZID destinee a recevoir des donnees d'identifica- 
tion de la carte, du proprietaire de celle-ci et des 
cles. En dehors de la zone d'identification ZID se 
situe la table de repertoire TR proprement dite qui 
debute a I'adresse INI et s'etend jusqu'a I'adresse 
hexadecimale 80FF. Comme indique sur la figure, 
la table repertoire TR contient les inscriptions 
successives d'un premier programme charge, dont 
le code de reference est appele "PR-APP-A", 



d'une longueur de 350 octets, dont I'adresse 
hexadecimale de debut d'execution de programme 
est egale a 8200 ainsi que I'adresse de debut de 
zone, et I'adresse de fin de zone egale a 835D, 

5 puis un programme reference "PR-APP-B" 
d'une longueur de 250 octets, ayant pour adresse 
de debut d'execution de programme la valeur 
hexadecimale 8365, pour I'adresse de debut de 
zone, 835E pour I'adresse de fin 8457, et enfin un 

70 programme reference "PR-APP-C", d'une lon- 
gueur de 180 octets, ayant pour adresse de debut 
d'execution de programme la valeur hexadecimale 
8460 pour I'adresse de debut de zone, 8458 et 
pour adresse de fin la valeur 850C. En effet, les 

75 adresses de debut d'execution de programme, 
comme findique cet exemple, ne coincident pas 
necessairement avec I'adresse de debut de zone 
allouee au meme programme, mais elles sont ne - 
cessairement comprises dans ladite zone allouee. 

20 On va decrire tout d'abord le cas ou un pro - 

gramme d'application deja charge dans la carte est 
appele sur les moyens d'acces d'entree/sortie. 

Toute demande d'execution d'un programme 
d'application fait Tobjet d'une procedure qui peut 

25 se decomposer en 5 etapes principales : 

- une etape d'initialisation qui peut inclure une 
procedure d'identification de la carte et son 
utilisateur, 

- une procedure de demande de I'application 
30 annoncee sur les moyens d'entree - sortie, 

- une procedure de recherche dans la table de 
repertoire TR pour determiner si I'application 
demandee existe, et dans I'affirmative, le 
chargement des donnees specifiques de 

35 I'application prelevees dans cette table, 

- le chargement des registres de limites, 

- et enfin ('execution proprement dite du pro - 
gramme d'application demande. 

Des la mise sous tension du microcircuit, la bas- 
40 cule bistable 58 est remise a zero en meme temps 
qu'un certain nombre de registres et notamment le 
compteur ordinal 55. Apres un eventuel protocole 
de reconnaissance mettant en jeu des donnees 
d'identification contenues dans la portion d'identi - 
45 fication ZID de la zone repertoire ZR, un pro- 
gramme d'application par exemple celui reference 
"PR-APP-B" est appele. 

Sous I'effet d'une routine preetablie, Tunite centrale 
10 effectue une recherche dans la table repertoire 

so TR de maniere a determiner si un tel programme 
d'application est present. Dans I'affirmative les va - 
leurs d'adresse de debut et de fin de ce program - 
me d'application, dans I'exemple les adresses 
hexadecimales 835E et 8457 respectivement, sont 

55 prelevees dans la table de repertoire TR et toujours 
sous I'effet d'une routine preetablie ces valeurs 
limites sont chargees dans les registres des limites 
25 et 26 respectivement. Jusqu'a present le fonc - 
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tionnement du microcircuit n'a fait appel qu'a des 
routines situees dans la memoire a lecture seule 
12 de sorte que le compteur ordinal n'a jamais 
franchi la limite des adresses designant la memoire 
programmable 13 soit dans notre exemple une 
adresse superieure a la valeur hexadecimale 7FFF. 
Dans i'etape operatoire qui suit et qui consiste a 
executer le programme appele, le compteur ordinal 
55 est charge avec I'adresse de debut d'execution 
du programme duplication appele, par exemple 
I'adresse hexadeciame 8365. Ceci entratne un 
changement d'etat de la bascule bistable 58 et 
procure sur la borne 60 un signal de verrouillage 
(LOC = 1 ). Ce signal a pour effet de verrouiller les 
registres de limites 25 et 26 et de bloquer la voie 
d'autorisation prioritaire formee par la branche 
comportant Tinverseur 41, la porte ET 42 et ('en- 
tree 40 de la porte de validation 32. Desormais les 
operations d'ecriture, de lecture et d'effacement de 
la memoire programmable ne peuvent plus §tre 
executees que dans la seule portion comprise dans 
les limites de debut et de fin du programme appele 
ou dans la zone publique ZP. Cet acces selectif va 
persister jusqu'a la mise hors tension du microcir- 
cuit. Les operations d'ecriture et de lecture dans la 
zone dtte publique ZP restent possibles au moyen 
du signal d'autorisation present sur I'entree 50 de 
la porte de validation 32 et provenant du decodeur 
d'adresse 51 qui reconnalt les adresses corres- 
pondant a cette zone ZP. 

On en vient maintenant a decrire le fonction - 
nement du microcircuit dans le cas ou un pro- 
gramme duplication doit etre charge dans la 
memoire programmable 13. Des la mise sous ten - 
sion du microcircuit, une etape d'initialisation est 
engagee qui est essentiellement similaire a celle 
deja mentionnee pour I'execution d'un programme 
d 'application. Dans une seconde etape, et sous le 
controle d'une routine fonctionnelle preetablie, le 
code de reference du programme a charger est 
annonce sur les entrees - sorties ainsi que le vo- 
lume de memoire necessaire a ce programme ex - 
prime par exemple en nombre d'octets. Dans une 
troisieme etape operatoire, et egalement sous I 'ef- 
fet d'une routine fonctionnelle preetablie, une re- 
cherche est effectuee dans la table repertoire TR 
contenue dans la zone de repertoire ZR de ma- 
niere a determiner si le programme demande a 
deja ete charge et sinon quelle est la demiere 
adresse limite de fin de programme inscrite dans la 
table. Cette adresse correspond egalement a 
I'adresse occupee la plus elevee de la zone ZA 
puisque les programmes ont ete charges succes- 
sivement a des adresses croissantes. Dans 
I'exemple il s'agit de la valeur hexadecimale 850C. 
La meme routine fonctionnelle determine d'une 
part la valeur d'adresse qui suit immediatement 
c'est-a-dire I'adresse hexadecimale 850D qui 



sera prevue comme valeur limite de debut du 
nouveau programme a charger et calcule d'autre 
part quelle sera I'adresse de fin de programme a 
charger compte tenu du volume de memoire an- 

5 nonce dans la seconde etape. Dans une quatrieme 
etape, ('unite centrale effectue un test pour deter- 
miner si I'adresse de fin de programme ainsi cal- 
culee est compatible avec I'adresse la plus elevee 
de la zone des applications ZA, puis, sous I'effet 

70 d'une routine preetablie, les valeurs limites de de- 
but et de fin de programme ainsi determinees sont 
chargees dans les registres de limites 25 et 26. Du 
fait que jusqu'a present I'unite centrale a effectue 
des routines fonctionnetles situees dans la me- 

75 moire a lecture seule 12, le compteur ordinal n'a 
jamais franchi la limite des valeurs d'adresse qui 
concernent la memoire programmable 13. Ainsi le 
signal de verrouillage/deverrouillage est dans son 
etat de deverrouillage (LOC = 0) ce qui a permis 

20 le chargement des registres des limites 25 et 26 
ainsi que la lecture de la table de repertoire au 
moyen de la voie d'autorisation prioritaire 41, 42 et 
32. Dans une cinquieme etape et sous I'effet d'une 
routine fonctionnelle, I'unite centrale 10 complete la 

25 table repertoire de la zone de repertoire ZR en 
inscrivant a la suite des references deja presentes, 
le code de reference, les valeurs limites d'adresses 
de debut et de fin precedemment determinees et 
qui concernent le programme d'application en voie 

30 de chargement, ainsi que I'adresse de debut 
d'execution de ce programme. 

Une sixieme etape operatoire, qui suit, 
concerne essentiellement le chargement dudit 
programme, chargement qui ne peut etre accompli 

35 qu'a I'interieur des limites fixees par les valeurs 
d'adresses de debut et de fin memorisees dans les 
registres des limites 25 et 26. Pendant ce charge- 
ment les registres de limites 25 et 26 peuvent ne 
pas etre verrouilles (LOC = 0) mais lesdits regis - 

40 tres effectuent le controle des operations d'ecriture 
de la meme maniere que s'ils avaient ete verrouil - 
les. La securite est neanmoins maintenue du fait 
que le chargement est execute sous le controle de 
I'unite centrale 10 par I'effet d'une routine fonc- 

45 tionnelle qui ne peut etre modifiee par un utilisa- 
teur. Toutefois, il est egalement possible d'activer 
la bascule 58 par programmation au moyen d'un 
signal transmis par la liaison 67 a la porte OU 66. 
Dans ce cas les registres de limites peuvent etre 

so verrouilles lors du chargement. Toute tentative de 
chargement d'un programme d'application d'une 
longueur superieure au volume de memoire an- 
nonce restera inefficace par I'effet du controle 
exerce par les registres de limites 25 et 26 et de la 

55 porte ET 30. 

Si on le desire I'etape de chargement du pro - 
gramme peut etre suivie par une verification des 
donnees chargees, une verification de signature 
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finale, un test de parite, et.... II est aise de detecter 
une tentative de chargement d'un programme de 
longueur superieure a la longueur annoncee du fait 
que la ou les dernieres donnees presentees au 
chargement ne sont pas en fait enregistrees dans 
la memoire programmable de sorte qu'une verifi- 
cation de ces donnees finales revele la tentative 
d'un chargement abusif qu ? il soit accidentel ou 
frauduleux. 

En se referant a nouveau a la figure 1, un 
dispositif additionnel pour la signalisation d'une 
anomalie de fonctionnement va maintenant etre 
decrit. Ce dispositif additionnel comporte une porte 
ET 62 a deux entrees, une porte OU 63 a 3 
entrees et un inverseur 64. 

L'inverseur 64 regoit en entree le signal de 
sortie de la porte de validation 32, et le transmet 
apres inversion, a une entree de la porte ET 62. 

La porte OU 63 a sa sortie connectee a Tautre 
entree de la porte ET 62 et regoit en entree les 
trois signaux de commande R, W, E destines a la 
memoire programmable 13, en formant ainsi la 
somme logique de ces signaux de commande. 

Lorsque Tune de ces operations est demandee, 
le signal en sortie de la porte OU 63 est a I'etat 
haut. Simultanement, si aucune des conditions 
d'autorisation n'est realisee, ce qui produit un si- 
gnal a I'etat bas en sortie de la porte OU 32, la 
porte ET 62 est alors activee et produit en sortie 
un signal renvoye a I'unite centrale 10, par exem - 
pie un signal d'interruption (INT = 1). 

Ainsi, dans le cas d'utilisation d'une interrup- 
tion, une anomalie de fonctionnement et plus par- 
ticulierement une demande non autorisee d'acces 
a la memoire programmable 13 aboutira a une 
interruption de fonctionnement du microcircuit 
(interruption non masquable) et on peut, si on le 
desire, produire un message d'avertissement sur le 
terminal d'exploitation de la carte. 

Le signal INT qui est produit en cas d'anomalie 
peut §tre utilise pour operer toute modification 
desirable du fonctionnement du microcircuit : par 
exemple invalider le programme qui a produit 
I'anomalie, voire invalider totalement le fonction- 
nement de la carte. 

Une consequence avantageuse de ('invention 
est que seules les routines fonctionnelles incrites 
dans la memoire a lecture seule devront etre ex - 
tensivement testees et approuvees alors que les 
programmes duplications pourront etre crees par 
diverses entites, sous leur propre responsabilite, et 
sans risque d' interference indue entre les applica- 
tions. 

Le microcircuit selon I'invention offre done une 
parfaite securite pour une utilisation de carte a 
puce multi - applications. 



Revendications 

1. Microcircuit pour carte a puce comprenant 
entre - autres : des moyens d'acces entree - 
5 sortie, au moins une memoire qui est pro - 

grammable et accessible par un espace 
d'adressage a adresses consecutives, un cir - 
cuit de controle d'adressage de cette memoire 
programmable determinant soit une inhibition, 

to soit une validation des commandes d'ecriture 

et/ou de lecture par fa comparaison de 
I'adresse demandee avec deux valeurs limites 
de debut et de fin d'une zone particuliere 
d'adresses, limites qui sont memorisees au 

75 sein du circuit de controle d'adressage lequel 

circuit comporte egalement une voie d'autori - 
sation prioritaire permettant de s'affranchir 
temporairement de ladite inhibition dans des 
circonstances predetermines et particulieres, 

20 caracterise en ce que, en vue d'un chargement 

et d'une exploitation de programmes d'appli - 
cations independants les uns des autres, le 
microcircuit est muni d'une unite centrale de 
microprocesseur, d'une memoire a lecture 

25 seule (ROM) contenant notamment des routi - 

nes fonctionnelles exclusivement executables 
par I'unite centrale et sous sa dependance, en 
ce que dans I'espace d'adressage de la me - 
moire programmable sont deiimitees une zone 

30 dite de repertoire et une zone dite des appli - 

cations, lesquelles zones sont exclusives Tune 
de I'autre, en ce que la zone de repertoire 
contient une table repertoire ou les adresses 
de debut et de fin ainsi qu'un code de refe - 

35 rence de chacun des programmes d'applica - 

tions susceptible d'etre charge dans une por - 
tion de la zone des applications, sont inscrits 
au fur et a mesure du chargement desdits 
programmes et en utilisant une desdites rou - 

40 tines fonctionnelles, en ce que le circuit de 

controle d'adressage est agence pour inhiber 
les commandes d'ecriture et de lecture de la 
memoire programmable pour des adresses qui 
se situent a I'exterieur de I'intervalle defini par 

45 les valeurs limites de debut et de fin d'une 

application designee prealablement sur les 
acces d'entree- sortie, limites qui sont me- 
morisees dans des registres verrouillables, 
appeles registres de limites, tandis que la voie 

so dite d'autorisation prioritaire comporte des 

moyens pour s'affranchir de ('inhibition preci - 
tee en autorisant I'ecriture et la lecture de la 
zone de repertoire a la condition exclusive que 
ces operations soient effectuees au moyen 

55 d'une desdites routines fonctionnelles durant 

une etape operatoire predeterminee durant 
laquelle les registres contenant les valeurs li - 
mites sont deverrouilles. 
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2. Microcircuit seion la revendication 1, caracte- 
rise en ce qu'il comporte une bascule bistable, 
placee dans un premier etat exclusivement iors 
d'une mise sous tension du microcircuit, puis 
placee dans un deuxieme etat oppose au 
premier des qu'un compteur ordinal associe a 
I'unite centrale, contient une valeur d'adresse 
comprise dans I'espace d'adressage de la 
memoire programmable, et en ce que cette 
bascule bistable delivre un signal de 
verrouillage/deverrouillage pour la commande 
de verrouillage des registres de limites et pour 
la commande de la voie d'autorisation priori - 
taire. 

3. Microcircuit selon la revendication 2, caracte - 
rise en ce que ladite bascule bistable peut 
egalement etre placee dans ledit deuxieme 
etat par un signal de commande delivre par 
I'unite centrale sous I'effet d'une routine tone - 
tionnelle prevue a cet effet. 

4. Microcircuit selon Tune des revendications 1 a 
3, caracterise en ce que le circuit de controle 
d'adressage comporte une porte OU dite de 
validation, dont la sortie commande la tran- 
smission des signaux d'ecriture et de lecture 
de la memoire programmable, en ce qu'une 
premiere entree de cette porte de validation 
regoit un signal resultant de la comparaison de 
toute adresse appelee avec le contenu des 
registres de limites, et une autre entree par 
laquelle s'effectue I'autorisation prioritaire, re- 
goit un signal resultant du produit logique entre 
le signal de verrouillage/deverrouillage et le 
signal de sortie d'un decodeur d'adresses re - 
connaissant les seules adresses de la zone de 
repertoire. 

5. Microcircuit selon la revendication 4, caracte - 
rise en ce qu'une zone dite "publique" est en 
outre prevue dans I'espace d'adressage de la 
memoire programmable, zone qui est distincte 
de la zone de repertoire et de la zone des 
application, et en ce que le circuit de controle 
d'adressage comporte un decodeur d'adresse 
supplemental reconnaissant les seules 
adresses de la zone publique, qui delivre en 
sortie un signal applique a une entree sup- 
plemental de la porte OU de validation. 

6. Microcircuit selon I'une des revendications 4 
ou 5, caracterise en ce qu'un signal de de- 
tection d'anomalie (INT) est produit en sortie 
d'une porte ET additionnelle dont une pre- 
miere entree regoit le signal issu de la porte 
de validation, et une deuxieme entree regoit la 
somme logique des signaux de commande de 



lecture, d'ecriture et d'effacement, a la sortie 
d'une porte OU additionnelle. 
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